







#### Positive and Negative Logic

Boolean values (zero and one) represent physical quantities such as voltage or state of an entity (door is open, light is off).

Assigning "1" to high value, and "0" to low value is called positive logic, and assigning "0" to high value, and "1" to low value is called negative logic.

## Example:

Function table of a physical device with 2 inputs and one output is shown below. If we use the positive logic, the device can be implemented with an AND gate.

In negative logic system, the device is implemented with an OR gate.

| Physical Device |    |         | Positive Logic |    |         | Negative Logic |    |         |
|-----------------|----|---------|----------------|----|---------|----------------|----|---------|
| Inputs:         |    | Output: | Inputs:        |    | Output: | Inputs:        |    | Output: |
| x1              | x2 | z       | ×1             | x2 | Z       | ×1             | x2 | Z       |
| L               | L  | L       | 0              | 0  | 0       | 1              | 1  | 1       |
| L               | Н  | L       | 0              | 1  | 0       | 1              | 0  | 1       |
| Н               | L  | L       | 1              | 0  | 0       | 0              | 1  | 1       |
| Н               | Н  | Н       | 1              | 1  | 1       | 0              | 0  | 0       |





License: http://creativecommons.org/licenses/by-nc-nd/3.0/

As a Boolean function has many different expressions it can be implemented in different ways using different logic gates.

**Example:** 
$$Z = A' \cdot B' \cdot (C + D)$$
 =  $(A' \cdot (B' \cdot (C + D)))$ 



Sometimes it would be necessary to manipulate logical expressions of functions according to currently available gates.

## Functional Completeness and Universal Gates

A set of logic operations is said to be **functionally complete**, if any Boolean function can be expressed using only this set of operations.

From the definition of the Boolean algebra {AND, OR, NOT} is obviously a functionally complete set.

Any function can be expressed in sum-of-products form, and a sum-of-products expression uses only the AND, OR, and NOT operations.

Since the set of operations {AND, OR, NOT} is functionally complete, any set of logic gates which can realize {AND, OR, NOT} is also functionally complete.

For example, {AND, NOT} is a functionally complete set of gates because OR can be realized using only AND and NOT.

De Morgan's Law:

$$(X'Y')' = X + Y$$

http://www.faculty.itu.edu.tr/buzluca http://www.buzluca.info



2011 - 2016

Feza BUZLUCA

3.9

**Digital Circuits** 

# Universal Logic Gates

If a single gate forms a functionally complete set by itself, then any Boolean function can be realized using only gates of that type.

This type of a gate is called universal logic gate.

- The NAND gate is an example of such a gate.
- NOT, AND, and OR can be realized using only NAND gates.
- Thus, any Boolean function can be realized using only NAND gates.
- Similarly, the set consisting only of the binary operator NOR is also functionally complete.
- All other logic functions can be realized using only NOR gates.

NAND (and also NOR) gates are called universal logic gates.

# Proof of completeness

To prove that NAND and NOR operators are functionally complete , we have to show that AND, OR, NOT operations can be implemented by using only NAND (or alternatively, NOR) gates.

NAND is denoted by symbol |

NOR is denoted by symbol  $\downarrow$ 



•NOT:

• AND:

$$x \cdot y = (x \mid y)'$$

• OR:

$$x+y = (x' | y')$$
 de Morgan

**NOR** 



$$x \cdot y = (x' \downarrow y')$$
 de Morgan

Feza BUZLUCA

$$x+y=(x \downarrow y)'$$

http://www.faculty.itu.edu.tr/buzluca

http://www.buzluca.info



2011 - 2016

3.11

Digital Circuits

### Relation between NAND and NOR

- NAND NOR Conversions
  - de Morgan:

1. 
$$(A + B)' = A' \cdot B'$$

3. 
$$(A' \cdot B')' = A + B$$

4. 
$$(A' + B')' = (A \cdot B)$$

- These expressions show that:
- 1. An AND gate with inverted inputs is the equivalent of the NOR gate.
- 2. An OR gate with inverted inputs is the equivalent of the NAND gate.
- 3. A NAND gate with inverted inputs is the equivalent of the OR gate.
- 4. A NOR gate with inverted inputs is the equivalent of the AND gate.









# Implementation of Boolean functions using only NAND (NOR) gates

As the binary operator NAND is functionally complete all Boolean functions can be implemented using only NAND gates.

NOR gates have the same property.

Implementation of Boolean functions in the SOP form using only NAND gates

Shortcut: In circuits in the SOP form, we can replace all AND gates and OR gates with NAND gates. These changes do not affect the output.

If we add NOT gates to the outputs of AND gates and to the inputs of the OR gates, we obtain NAND gates. (See 3.12)

If we always add inverters in pairs (NOT-NOT), the function realized by the circuit will not change. (a')' = a (Involution)







http://www.facultv.itu.edu.tr/buzluca http://www.buzluca.info

**@ ⊕ ⊕** 

Feza BUZLUCA 2011 - 2016

**Digital Circuits** 

License: http://creativecommons.org/licenses/by-nc-nd/3.0/

Example (cont'd):

#### Algebraic conversion:

Expression is inverted twice. (Z')' = Z (Involution)

$$Z = (A \bullet B) + (C \bullet D)$$

(SoP form)

$$= [((A \bullet B) + (C \bullet D))']'$$

(De Morgan)

$$= [(A \bullet B)' \bullet (C \bullet D)']'$$
$$= (A \mid B) \mid (C \mid D)$$

(only NAND gates)

## Algebraic verification:





$$Z = [ (A \bullet B)' \bullet (C \bullet D)' ]'$$

Expression with NANDs (right part)

$$= [ (A' + B') \cdot (C' + D') ]'$$

$$= [(A_1 + B_2) \bullet (C_1 + D_2)]$$

= 
$$[(A' + B')' + (C' + D')']$$
  
=  $(A \cdot B) + (C \cdot D) \checkmark$ 

Expression of the circuit on left

http://www.faculty.itu.edu.tr/buzluca http://www.buzluca.info



# Implementation with gates having limited number of inputs

Sometimes, it is necessary to implement products (or sums) with many literals using gates having only 2 inputs.

#### Example:

 $Z = \overline{ABC} + \overline{ACD}$ 

Implement this expression using only 2-input NAND Gates.

#### Solution 1:

1. Implementation with the classical gates of the Boolean algebra



2. Inserting NOT gates to obtain NAND gates

http://www.faculty.itu.edu.tr/buzluca http://www.buzluca.info 2011 - 2016

Feza BUZLUCA

3.15

#### Digital Circuits

Example (cont'd):

#### Solution 1:

3. Implementation with 2-input NAND gates



# Solution 2:

Manipulating the original expression to obtain a simpler circuit

$$Z = \overline{ABC} + \overline{ACD} = \overline{A(BC + \overline{CD})}$$



The circuit in solution 2 is cheaper to implement than the circuit in solution 1.

Therefore solution 2 is preferable to solution 1.

http://www.faculty.itu.edu.tr/buzluca

 $\bigcirc \bigcirc \bigcirc \bigcirc \bigcirc \bigcirc \bigcirc$ 

2011 - 2016

Feza BUZLUCA

3.16





# Implementation of Boolean functions in the POS form using only NOR gates

Shortcut: In circuits in the POS form, we can replace all AND gates and OR gates with NOR gates.

#### Details:

If we add NOT gates to the outputs of OR gates, and to the inputs of the AND gates, we obtain NOR gates. (See 3.12)

Remember: If we always add inverters in pairs, the function realized by the circuit will not change. (a')' = a (Involution)







#### Propagation Delay

When the input to a logic gate is changed, the output will not change instantaneously. The transistors and other switching elements within the gate take a finite time to react to a change in input.

The delay in the change in output with respect to the input is called **propagation** delay.



The shorter the propagation delay, the higher is **the speed** of the logic circuit. The inputs of a circuit must be kept stable (constant) until it finishes its previous job A new input value can be applied only after the previous input value has been processed.

http://www.faculty.itu.edu.tr/buzluca http://www.buzluca.info



2011 - 2016

Feza BUZLUCA

3.21

Digital Circuits

# Hazards caused by propagation delays

A digital circuit may malfunction due to timing problems.

Such timing problems which arise due to delays are referred to as hazards. If an input propagates through multiple paths to the output, unexpected output values (hazards) may appear at the output.

### Example:

Input B has two different paths (shown with red and yellow lines) to the output Z.



When the inputs A, B, and C are all zero (A=0, B=0, C=0), the output will also be zero (Z=0).

In this state, if the value of input B is changed to 1, the output should not change its value (A=0, B=1, C=0  $\rightarrow$  Z=0).

However due to the different propagation delays in the paths from B to Z, a "short" change (hazard) appears at the output.

http://www.faculty.itu.edu.tr/buzluca http://www.buzluca.info <u>@</u> ⊕

2011 - 2016

Feza BUZLUCA

3.22

# Types of hazards:

- a) Static 0: The output momentarily goes to 1 when it should stay a constant 0.
  The output becomes 1 for a short time and gets back to 0.
  A static 0-hazard may occur in a product-of-sums implementation.
- b) Static 1: The output momentarily goes to 0 when it should stay a constant 1.
  The output becomes 0 (from 1) and gets back to 1 after a short time.
  A static 1-hazard may occur in a sum-of-products implementation.
- c) Dynamic: When the output is supposed to change from 0 to 1 (or 1 to 0), the output changes three or more times (i.e., oscillates).



http://www.faculty.itu.edu.tr/buzluca http://www.buzluca.info



2011 - 2016

Feza BUZLUCA

3.23



# Avoiding hazards:



Example: The circuit on the left (SoP implementation) has output Z=1 when A=1, B=1 and C=1.

In this state if B becomes 0 (1 $\rightarrow$ 0), the output should stay as Z=1. However, **static 1 hazard** occurs at the output.

Possible hazards can be foreseen from the Karnaugh map.



A change in B (1 $\to$ 0) causes a transition from a prime implicant to another. These type of transitions cause hazards because of delays.

To avoid the hazards, **consensus** of the transitions are added to the design which increases the cost.



Z= AB + B'C + **AC** 

http://www.faculty.itu.edu.tr/buzluca



2011 - 2016

Feza BUZLUCA

3.24